﻿using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

using System.Data.OleDb; //подключение OleDb
using Domain; //подключение проекта Domain
using System.Data; //подключение System.Data, нужна ниже в коде
using Setting;

namespace Session
{
    public class BrokerTp
    {      
        OleDbConnection connection; // объявление OleDbConnection
        OleDbCommand command; // объявление OleDbCommand
        Props prop = new Props();
        string dbpath;

        private void readSetting()
        {
            prop.ReadXml();
            dbpath = Convert.ToString(prop.Fields.dbpath);

        }

        private void ConnectTo() // функция подключения БД
        {
            readSetting();
            connection = new OleDbConnection(@" Provider = Microsoft.ACE.OLEDB.12.0; Data Source =" + dbpath + "; Persist Security Info = False;"); // объявление техналогии и пути
            command = connection.CreateCommand(); // Создает и возвращает объект OleDbCommand, связанный с объектом OleDbConnection.

        }


        public BrokerTp() // функция для класса BrokerTp
        {
            ConnectTo(); // вызов функции подключения
        }

        public void Insert (Dm_Type tp) // функция добавления новой записи
        {
            try
            {
                command.CommandText = "INSERT INTO T_Type (type) VALUES('" + tp.Type + "')"; // текст SQL команды
                command.CommandType = CommandType.Text; // Возвращает или задает значение, указывающее, как будет интерпретироваться свойство CommandText.
                connection.Open(); // открыте подключения

                command.ExecuteNonQuery(); // возвращает количество задействованных в инструкции строк.
            }

            catch (Exception ) 
            {
                throw;
            }

            finally
            {
                if (connection != null) // условие на проверку открытось поделючения
                {
                    connection.Close(); // закрытие подключения
                }
            }

        }

        public void Update(Dm_Type OldTp, Dm_Type NewTp) // функция обновления записи по id
        {
            try
            {
                command.CommandText = "UPDATE T_Type SET type='" + NewTp.Type + "' WHERE id_type=" + OldTp.Id_type; // текст SQL команды
                command.CommandType = CommandType.Text; // Возвращает или задает значение, указывающее, как будет интерпретироваться свойство CommandText.
                connection.Open(); // открыте подключения

                command.ExecuteNonQuery(); // возвращает количество задействованных в инструкции строк.

            }

            catch (Exception)
            {
                throw;
            }

            finally
            {
                if (connection != null) // условие на проверку открытось поделючения
                {
                    connection.Close(); // закрытие подключения
                }
            }
        }

        public void Delete(Dm_Type tp) // функция удаления записи по id
        {
            try
            {
                command.CommandText = "DELETE FROM T_Type WHERE Id_type=" + tp.Id_type; // текст SQL команды
                command.CommandType = CommandType.Text; // Возвращает или задает значение, указывающее, как будет интерпретироваться свойство CommandText.
                connection.Open(); // открыте подключения

                command.ExecuteNonQuery(); // возвращает количество задействованных в инструкции строк.

            }

            catch (Exception)
            {
                throw;
            }

            finally
            {
                if (connection != null) // условие на проверку открытось поделючения
                {
                    connection.Close(); // закрытие подключения
                }
            }
        }

        public List<Dm_Type> FillGrid() // функция для заполнения Grid
        {
            List<Dm_Type> tpList = new List<Dm_Type>(); // объявление List< >

            try
            {
                command.CommandText = "SELECT * FROM T_Type"; // текст SQL команды
                command.CommandType = CommandType.Text; // Возвращает или задает значение, указывающее, как будет интерпретироваться свойство CommandText.
                connection.Open(); // открыте подключения

                OleDbDataReader reader = command.ExecuteReader(); // объявление OleDbDataReader

                while (reader.Read()) // цикл на чтение
                {
                    Dm_Type tp = new Dm_Type(); // объявление Dm_Type


                    tp.Id_type = Convert.ToInt32(reader["Id_type"].ToString()); // чтение Id_type из БД и занисение информации в tp.Id_type                
                    tp.Type = reader["type"].ToString(); // чтение type из БД и занисение информации в tp.Type


                    tpList.Add(tp); // добавление данных в List< >
                }

                return tpList; // возврат List< >
            }

            catch (Exception)
            {
                throw;
            }

            finally
            {
                if (connection != null) // условие на проверку открытось поделючения
                {
                    connection.Close(); // закрытие подключения
                }
            }

        }
  
    }
}
